配置屏参


1. 屏参配置文件介绍

屏参配置文件在alkaid中的路径为project/board/ini/misc/config.ini

系统启动过程中会去解析屏参配置文件,然后将不同屏参保存到系统中,给显示模块使用。

显示模块会根据用户调用API的参数设定向系统获取所需屏参。

屏参配置文件由section、variable name组成:

  • section:

    文件中方括号中的字段

  • variable name:

    文件中等号左边的字段,等号右边是给variable name赋的值

配置文件中section是唯一的,不允许存在同名section,但是允许存在同名variable name,比如上图中的section DACOUT_576I只能有一个,但是m_pPanelName可以出现在不同的section中。这样系统可以根据不同的section来区分variable name,然后就可以添加不同的屏参。

variable name的字段是系统中预先定义好的,在添加新的屏参时,只能填写系统中现有的variable name字段,新增或者修改variable name需要告知相关owner,否则系统无法识别,比如m_pPanelName这个variable name,在新增屏参时只能使用m_pPanelName去定义新的panel name。

在给variable name赋值时,如果value需要换行,可以在行尾加'\'作为换行符,如果variable name的value有多个,可以用{}将所有的value括起来,并且每个value后加逗号来表示该字段结束。如下图所示:


2. 新增屏参

  1. 给新的屏参定义一个section name,可以随意定义但是不能和现有section name相同

  2. 将新的屏参section name追加到ROOT section中的m_pnlList变量中(不同接口的LCD section只能存在一个,比如m_pnlList中已经存在一个TTL的panel section name,那么如果想要添加新的TTL,只能删除掉之前存在的section)

  3. 将新的屏参参数添加到新的section中,如下:

    [SAT070AT50H18BH]
    m_pPanelName = "SAT070AT50H18BH_1024x600";
    m_bPanelDither = 0;
    m_ePanelLinkType = 0; #0:ttl 1:lvds 11:mipi
    
    m_bPanelInvDCLK = 0;
    m_bPanelInvDE = 0;
    m_bPanelInvHSync = 0;
    m_bPanelInvVSync = 0;
    
    m_wPanelHSyncWidth = 48;
    m_wPanelHSyncBackPorch = 46;
    m_wPanelVSyncWidth = 4;
    m_wPanelVBackPorch = 23;
    m_wPanelHStart = 98;
    m_wPanelVStart = 27;
    m_wPanelWidth = 1024;
    m_wPanelHeight = 600;
    
    m_wPanelHTotal = 1344;
    m_wPanelVTotal = 635;
    m_wPanelDCLK = 51;
    
    m_wSpreadSpectrumStep = 0;
    m_wSpreadSpectrumSpan = 0;
    
    m_eOutputFormatBitMode = 2; #0:10bit 1:6bit 2:8bit 3:565bit
    
    m_ucPanelSwapChnR = 3;
    m_ucPanelSwapChnG = 2;
    m_ucPanelSwapChnB = 1;
    m_ucPanelSwapRgbML = 1;
    

3. 屏参参数说明

参数 描述
m_pPanelName panel name
m_bPanelDither 1:enable Dither
0:disable Dither
m_ePanelLinkType 接口类型 TTL :0 MIPI_DSI :10
m_bPanelInvDCLK Pixel clk极性反转
m_bPanelInvDE DE极性反转
m_bPanelInvHSync Hsync极性反转
m_bPanelInvVSync Vsync极性反转
m_wPanelHSyncWidth 行同步信号脉宽
m_wPanelHSyncBackPorch 行同步信号后肩
m_wPanelVSyncWidth 场同步信号脉宽
m_wPanelVBackPorch 场同步信号后肩
m_wPanelHStart m_wPanelHSyncWidth+m_wPanelHSyncBackPorch
m_wPanelVStart m_wPanelVSyncWidth+ m_wPanelVBackPorch
m_wPanelWidth 行有效像素点数
m_wPanelHeight 场有效行数
m_wPanelHTotal m_wPanelWidth+m_wPanelHSyncWidth+m_wPanelHSyncBackPorch+HsyncFrontPorch
m_wPanelVTotal m_wPanelHeight+m_wPanelVSyncWidth+ m_wPanelVBackPorch+VsyncFrontPorch
m_wPanelDCLK m_wPanelHTotal*m_wPanelVTotal*fps(IP内部使用clk)
m_wSpreadSpectrumFreq 时钟延展幅度调制(详见展频计算
m_wSpreadSpectrumRatio 时钟延展频率调制(详见展频计算
m_eOutputFormatBitMode 10BIT :0
6BIT :1
8BIT :2
565BIT :3
m_ucPanelSwapChnR Swap Channel R
0:default
1:select R 
2:select G
3:select B
m_ucPanelSwapChnG Swap Channel G
0:default
1:select R 
2:select G
3:select B
m_ucPanelSwapChnB Swap Channel B
0:default
1:select R 
2:select G
3:select B
m_ucPanelSwapRgbML Swap Rgb MSB/LSB
0:disable M/L swap
1:enable M/L swap

如果是MIPI panel,还需要对MIPI DSI进行配置。
MIPI DSI参数说明:

参数 描述
m_wHsTrail Default: 5
m_wHsPrpr Default: 3
m_wHsZero Default: 5
m_wClkHsPrpr Default: 10
m_wClkHsExit Default: 14
m_wClkTrail Default: 3
m_wClkZero Default: 12
m_wClkHsPost Default: 10
m_wDaHsExit Default: 5
m_wContDet Default:0
m_wLpx Default:16
m_wTaGet Default:26
m_wTaSure Default:24
m_wTaGo Default:50
m_wHactive Follow 屏参设定
m_wHpw Follow 屏参设定
m_wHbp Follow 屏参设定
m_wHfp Follow 屏参设定
m_wVactive Follow 屏参设定
m_wVpw Follow 屏参设定
m_wVbp Follow 屏参设定
m_wVfp Follow 屏参设定
m_wBllp 0
m_wFps Default:60
m_eLaneNum one lane :1
two lane :2
three lane :3
four lane :4
m_eFormat RGB565 :0
RGB666 :1
LOOSELY_RGB666 :2
RGB888 :3
m_eCtrlMode CMD_MODE :0
SYNC_PULSE :1
SYNC_EVENT :2
BURST_MODE :3
m_ucClkLane Clk lane selection(default:2)
0:select chn0
1:select chn1
2:select chn2
3:select chn3
4:select chn4
m_ucDataLane0 data lane0 selection(default:4)
0:select chn0
1:select chn1
2:select chn2
3:select chn3
4:select chn4
m_ucDataLane1 data lane1 selection(default:3)
0:select chn0
1:select chn1
2:select chn2
3:select chn3
4:select chn4
m_ucDataLane2 data lane2 selection(default:1)
0:select chn0
1:select chn1
2:select chn2
3:select chn3
4:select chn4
m_ucDataLane3 data lane3 selection(default:0)
0:select chn0
1:select chn1
2:select chn2
3:select chn3
4:select chn4
m_pCmdBuff Mipi panel cmd
m_pCmdBuff=
{
  Cmd, parameter cnt, parameter0, parameter1, … ,  
Cmd, parameter cnt, parameter0, parameter1, … ,
  Cmd, parameter cnt, parameter0, parameter1, … ,  
………
}
m_ucPolCh0 Chn0极性
0:default
1:positive
2:negative
m_ucPolCh1 Chn1极性
0:default
1:positive
2:negative
m_ucPolCh2 Chn2极性
0:default
1:positive
2:negative
m_ucPolCh3 Chn3极性
0:default
1:positive
2:negative
m_ucPolCh4 Chn4极性
0:default
1:positive
2:negative

根据屏规格书填写屏参

在屏规格书中找到Timing相关部分,如下表定义

屏规格书中Timing定义和屏参参数对应如下表所示

m_wPanelHSyncWidth HSYNC period time
m_wPanelHSyncBackPorch 参考HSYNC blanking的要求 根据上表,如果HSYNC blanking为320,那么m_wPanelHSyncBackPorch要小于320,差值部分为hsync front porch大小
m_wPanelVSyncWidth VSYNC period time
m_wPanelVBackPorch 参考VSYNC blanking的要求 根据上表,如果VSYNC blanking为35,那么m_wPanelVBackPorch要小于35,差值部分为vsync front porch大小
m_wPanelHStart m_wPanelHSyncWidth+m_wPanelHSyncBackPorch
m_wPanelVStart m_wPanelVSyncWidth+ m_wPanelVBackPorch
m_wPanelWidth Horizonial display area 
m_wPanelHeight Vertical display area
m_wPanelHTotal m_wPanelWidth+HSYNC blanking
m_wPanelVTotal m_wPanelHeight+VSYNC blanking
m_wPanelDCLK m_wPanelHTotal*m_wPanelVTotal*fps

如果是MIPI panel,还需要配置MIPI AC timing相关参数,首先在panel规格书中找到MIPI timing specification部分

UI的计算方法:

H_Total = HACT+HPW+HBP+HFP

V_Total = VACT+VPW+VBP+VFP

BitsPerPixel=24(RGB888)/18(RGB666)/16(RGB565)

Bitrate = H_Total*V_Total*FPS*BitsPerPixel/lane number

UI = 1/Bitrate

比如表格中HS-PREPARE的要求是大于40ns+4*UI并且小于85ns+6*UI,那么对应MIPI AC timing中的参数

(40ns+4*UI)/8*UI \< m_wHsTrail \< (85ns+6*UI)/8*UI

其他MIPI AC timing中参数计算方法同上。

注意:

当前这套屏参设置需要更新:config_tool/mi_disp/mhal,若涉及uboot 点屏需要更新uboot。